WORLD INTELLECTUAL PROPH 
IntematioaaJ Bui 



PCX 

INTERNATIONAL APPUCATION PUBUSHED UNDER 




wo 960797IA1 



(51) Internatioiial Patent Classification ^ : 
G06F 13/38 



Al 



(11) International Publication Number; WO 96A)7971 

(43) Internationa] PubUcatlon Date: 14 March 1996 (14.03.96) 



(21) International AppUcation Number: PCT/US9S/I0S25 

(22) International Piling Date: 17 August 1995 (17.08.95) 



(30) Priority Data: 

08/303^38 



9 September 1994 (09.09.94) US 



(71) AppUcant: MEDL\LINK TECHNOLOGIES CORPORATION 

fUS/US); Suite 300. 18 West Mercer Street, Seattle, WA 
98119 (US). 

(72) Inventors: WARMAN, David. J.; 10211 N.E. Roberts Road, 

Bainbridge Island, WA 98110 (US). LACAS. Mark. A.; 
2320 First Avenue. The Loft, Seattle. WA 98121 (US). 

(74) Agent: KINDNESS, Gary, S.; Christenscn. O'Connor, Johnson 
& Kindness. Suite 2800, 1420 Fifth Avenue, Seattle. WA 
98101 (US). 



(81) Designated SUtes: CA. JP. European patent (AT, BE, CH. DE, 
DK. ES, FR, GB. GR. IE. IT. LU. MC. NL. PT. SE). 



Published 

With inxemationai search report. 

Before the expiration of the time limit for amending the 
claims and to be republished in the event of the receipt of 
amendments. 



(54) Title: METHOD AND APPARATUS FOR AUTOMATICALLY CONFIGURING AN INTERFACE 



(57) Abstract 

Method and apparatus for allowing an electnmic 
device (16) to communicate with one or more other 
electronic devices (14. 18. 22» 24, 52) via various 
conununication protocols. The apparatus includes an 
I/O board (30) and a processor board (32). The I/O 
board (30) includes a plug (64. .66) for connecting to 
a particular typid; of transmission medium (10) and an 
electronic identifier (76) providing an identification of a 
first communication protocol with which the I/O board 
(30) is constructed to be used. The I/O board (30) and the 
processor board (32) are coupled together by a detachable 
connector (71). Tte ^processor board (32) includes a 
processor (90) and memoiy (90» 92). By disconnecting 
the I/O board (30) from ^ processor board (32), another 
I/O board (58) that is constructed to be used with a second 
communication protocol can be coupled to the process^ 
board (32). The memory (90, 92) on the processor board 
(32) stores two imits of progrsm code (134, 136), one 
of which is used to c<mununicate according to the first 
c omm u n ication protocol and the other of which is used 
to communicate acccndihg to the seoxtd communication 
protocol. To ButomaticaUy configure itself, die processor 
board (32) reads die electronic identifier (76) on die I/O 
board (32. 58) connected to dse processor board (32). and 
based diercon selects the appropriate unit of program code 
(134, 136) so that the electronic device (16) cooununicates 
according to the specified communication protocol. 
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METHOD AND APPARATUS FOR AUTOMATICALLY 
CONnGURING AN INTERFACE 
^igl^ 9f the Tnvention 
TWs invention relates to methods and apparatus for interfedng an electronic 
5 device with one or more other electronic devices and, more particularly, methods and 
apparatus for provicUng a network interfece or a point-to-point intcrfece. 

T>aclc ffround o f the Invention 
Electronic devices are being interconnected with increasing frequency. For 
example, in the music industry, amplifiers, equalizers, musical instnmients, and 
1 0 various other devices are commonly interconnected to a control panel that can control 
the various devices. The various devices can also be interconnected to allow the 
devices to communicate with one another. Various transmission media such as fiber 
optic cables, coaxial cables, ribbon cables, and twisted wire pair cables can be used to 
interconnect electronic devices to allow the devices to communicate with one another. 
15 Furthermore, various commumcation protocols exist. 

Typicalfy, an interfece card is included in an electronic device to aUow the 
electronic device to communicate whh other devices via a particular type of 
transmission medhim and a particular communication protocol That is, the interface 
card is constructed for use with a particular type of transmission medwm and a 
20 particular type of communication protocol. As a result, if it is desired that an 
electronic device communicate via a different transmisaon medrnm or a diflferent 
communication protocol than the one in use, the device's interfece card must be 
changed to one dedicated to the desired type of transmission medhrai and 
communication protocol. Unfortunately, interfece cards are expensive because typical 
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various communication protocols is provided. The ^paratus includes an I/O board 
and a processor board. The I/O board includes a plug, a driver, an electronic 
identifier, and a connector The I/O board is connectablc to a particular type of 
transmission medium via the plug. The driver is coupled to the plug for producing 

5 signals on the transmission mediunt The dectronic identifiw provides an 
identification of a first commumcation protocol with which the I/O board is 
constructed to be used. The processor board includes a connector, memory, and a 
processor coupled to the mwnory and the connector. The processor board and I/O 
board are coupled together by connecting their connectors. Disconnecting the I/O 

10 board fi^om the processor board allows another I/O board that is constructed to be 
used with a second communication protocol to be coupled to the processor board. 

The memory on the processor board stores two units of program code, one of 
which is used to communicate according to the first communication protocol and the 
other of which is used to commimicate according to the second communication 

15 protocol. The processor reads the electronic identifier on the I/O board connected to 
the processor board, and analyzes the identification provided by the electronic 
idcntifiCT to determine which of the two communication protocols is to be followed. 
The processor then selects the appropriate unit of program code in the memory, Le., if 
the identification specifies the first communication protocol, the corresponding 

20 program code is selected. The processor executes this.unit of program code so that 
the electronic device communicates with one or more other devices according to the 
specified commimication protocol. 

In accordance with fiirther aspects of the invention, the first communication 
protocol is a bus network communication protocol and the second communication 

25 protocol is a point-to-point communication protocol. Furthermore, in one preferred 
embodiment of the inveiition, the I/O board that is constructed to be used with the 
first communication protocol is connectable to a fiber optic cable. The second I/O 
board that is constructed to be used with the second communicatioh protocol is 
connectable to a RS232 cable. 

30 In accordance with fiirther aspects of the mvention, the processor included on 

the processor board requires no program code fioni the I/O board. 

In accordance with still fiuther aspects of the invention, the electronic 
identifier comprises a dip switch. 

In accordance with still fiirther aspects of the invention, the identification 

35 provided by the electronic identifier on the I/O board also identifies the baud rate at 
which the I/O board is intended to be used. The processor on the processor board 
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reference to the following detailed desoiption, ^en taken in conjunction with the 
accompanying drawings, wherdn: 

FIGURE 1 is a pictorial diagram of electronic devices interconnected in a bus 
networic configuration with which the present invention can be used; 
S FIGURE 2 is a block diagram of the electronic devices and bus network 

shown inFIGURE I; 

FIGURE 3 is a block diagram representation of two electronic devices 
interconnected in a point-to-point configuration with vMch the present invention can 
be used; 

10 FIGURE 4 is a block diagram of an amplifier including a processor board and 

an I/O board formed in accordance with the invention; 

FIGURE 5 is a blotk diagram representation of a software/firmware paradigm 
that is preferably used in the processor board provided by the present invention; and 
FIGURE 6 is a flow diagram of a method of automatically configuring the 

1 5 processor board based upon the I/O board that is connected to the processor board, in 
accordance with the invention. 

Detailed Descriptjon of the Preferred Em bodiment 
FIGURES 1 and 2 illustrate a bus network 10 interconnecting various 
electronic devices 12 with which the present invention can be used so that they can be 

20 controlled by signals on the network; The electronic devices shown include two 
audio amplifiers 14, 16, an audio equalizer 18, and two personal computera22, 24. 
Other devices necessary to a complete sound system and their interconnection to the 
illustrated devices are not shown since they do not form part of this invention. 

As shown in FIGURE 2, the personal computers 22, 24 are connected to the 

25 bus network 10 by way of bridges 26. In contrast, the amplifim 14, 16 and the 
equalizer 18 eadi include an I/O board 30 and a processor board 32 formed in 
accordance with the invention to allow the devices to be directly connected to the bus 
network 10. The I/O board 30 is q>ecifically constructed for use with the bus 
network configuration and a particular type of transnussiori medhim, whereas the 

30 processor board 32 can be used with different commumcation configurations and 
transmission media. The processor board 32 is coupled to the I/O board 30 by way of 
connectors so that the I/O board 30 can be ea^ connected to and disconnected fi^om 
the processor board 32. By disconnecting the I/O board 30 firom the processor 
board 32, another I/O board constructed for use with a different communication 

35 configuration and/or transmission media can be connected to the processor board 32. 
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appropriate function, possibly including sending a response packet back to the 
equalizer 18. 

The processor boards 32 in the devices 14, 16, 18 are connected to other 
components in the devices to either control the devices directly or to control the 
S devices in conjunction with other processors or controllers within the devices. For 
example, the amplifier 16 can include various analog electronics that are controlled by 
the processor board 32 based upon packets received over the bus networic 10. 
Furthermore, while the processor board 32 is illustrated as a separate board, the 
components of the processor board 32 could be integrated into a larger board in the 

10 device, or the processor board 32 could be a section of a larger board. 

The personal computers 22, 24 are not directly connected to the bus 
network 10. Rather, the personal computers 22, 24 are connected via RS232 
interfaces 34 and the bridges 26. Standard personal computers typically include an 
RS232 card 36 for communicating with external devices such as printers. RS232 is 

15 an interface standard that specifies signal voltage levels, etc. RS232 is also a byte- 
levei communication protocol that specifies start bits, stop bits, etc. for sending bytes 
of data. Goierally, a higher level communication protocol is used on top of the 
RS232 byte-level communication protocol. 

As show in FIGURE 2, the personal computers 22, 24 each include an RS232 

20 interface card 36 and an RS232 cable 38. The personal computers 22, 24 also include 
software defining a point-to-point communication protocol that is used on top of the 
RS232 byte-level protocol The bridges 26 provide the interfitce between the RS232 
cables 38 and the bus networic 10. Each bridge 26 includes a RS23 2 I/O card 40 for 
connecting to the RS232 cable 38, and a second I/O card 42 that is constructed for 

25 connecting to the transmission medium of the bus network 10. The bridges 26 
indude a bridge processor board 44 connected to each of the I/O boards 40, 42, to 
translate between the point-to-point communication protocol and the bus network 
comnwmicarion protocol used on the bus networic 10. 

The bus networic 10 shown in FIGURES 1 and 2 can be formed of various 

30 transmission media such as glass or plastic fiber optic cables, coaxial cables, twisted 
wire pair cables, ribbon cieibles, etc. In the music mdustxy it is generally preferable to 
use fiber optic cables, as fiber optic cables are highly immune to electromagnetic 
mterference and ground loops, and are capable of carrying signals over long distances 
without significant attenuation. As described herein, the bus network 10 represents 

35 fiber optic cables. Accordingly, the I/O board 30 shown in FIGURE 2 is constructed 
for use with fiber optic cables. As previously e7q>lained, the I/O board 30 can be 
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This point-to-point conununication protocol is referred to herein as the MediaWAN 
protocol. 

With respect to FIGURE 3, the amplifier 50 includes the I/O board 58 and the 
processor board 32, which is identical to the processor boards 32 illustrated in 

5 FIGURE2. The I/O board 58 is similar to the I/O boards 30 shown in FIGURE 2, 
except that the I/O board 58 is constructed for use with a RS232 cable. The 
processor board 32 included in the amplifier 50 controls the communication of the 
amplifier 50 using separate program code for communicating in accordance with the 
MediaWAN point-to-point communication protocol. 

10 With respect to FIGURE 2, the bridge processor boards 44 include program 

code for both the MediaWAN point-to-point communication protocol and the 
MediaLink bus network communication protocol. The MediaWAN and MediaLink 
protocols are simultaneously used to provide the interface fi*om the RS232 cables 38 
to the bus network 10. 

15 The amplifier 50 shown in FIGURE 3 can be connected to the bus network 10 

illustrated in FIGURE 2 by simply replacing the I/O board 58 with an I/O board 30. 
v^ch is constructed for use with the bus netwoA 10. As briefly explained above and 
as explained in detail below, the processor board 32 includes hardware and program 
code so that the processor board automatically senses the type of commxmication 

20 protocol to use based upon an identifier on the I/O board that is connected to the 
processor board 32. 

Processor Board and I/O Board 
FIGURE 4 illustrates in greater detail the I/O board 30 and the processor 
board 32 in the anq>lifier 16 shown in FIGURES 1 and 2. The I/O board 30 includes 

25 two sets of plugs 64, 66, two drivers 72, 74, an electronic identifier 76, a shift 
register 75, and an iq)plication specific integrated circuit (ASIC) 73. The I/O 
board 30 is coupled to the processor board 32 by a ribbon cable 71. The processor 
board 32 inchides a processor 90, an electronically erasable and programmable read- 
only memory (EEPROM) 92, a random access memory (RAM) 94, an application 

30 specific integrated circuit (ASIC) 73, and a timing dodc C-C, oscillator) 96. 

With respect to the I/O board 30, the plugs 64, 66 are constructed to receive 
two fiber optic cables 68, 70, as shown in FIGURE 1. The drivers 72, 74 are 
respectively coupled to the plugs 64, 66 to produce light signals at the plugs to which 
the drivers are connected. The two sets of plugs 64, 66 are provided to allow the I/O 

35 board 30 to be used on a bus network 10, as illustrated in block diagram form in 
FIGURE 2. With fiber optic cables it is generally not possible to tap oflf of the cable. 
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register 75 is used to allow a serial control line of the processor 90 to control the 
ASIC 73, which requires parallel control lines. For example, in one preferred 
embodiment, the ASIC 73 requires four parallel lines (bits) to select its mode. The 
shift registo^ 75 shifts four bits sent over the s^al control line of the process 90 into 
5 four bits, which are applied to the ASIC 73 . 

The electronic identifier 76 included on the I/O board 30 identifies the 
communication protocol and the baud rate with which the I/O board 30 is constructed 
to be used. In one preferred embodiment, the electronic identifier 76 is a dip switch 
set to identify the baud rate and the communication protocol. However, those skilled 

10 in the pertinent art will readily recognize that other devices could easily be used to 
serve as the identifier 76. For example, the electronic identifier 76 could be formed of 
electronic circuitry wired to uniquely identify the baud rate and communication 
protocol. The identifio* 76 could also be formed of a small memory device storing 
one or more bytes of data to uniquely identify the baud rate and communication 

15 protocol. With respea to the use of a dip switch for the electronic identifier 76, 
multiple pins on the dip switch must be read to determine the identification provided 
by the dip switch. The. shift register 75 is connected to these pins, and converts the 
parallel data into serial data that is sent to the processor 90. 

In one preferred embodiment, one end of the ribbon cable 71 is secured to the 

20 processor board 32 and the I/O board 30 inchides a connector to which the other end 
of the ribbon cable 71 can be connected. The ribbon cormector 71 can be 
disconnected Srom the I/O board 30, so that a different I/O board can be cormected to 
the processor board 32. In one preferred embodiment of the invention, at least two 
types of I/O boards are provided, one for use with a bus network conununication 

IS protocol (e.g., the Medialink protocol) and the other for use with a point-to-point 
communication protocol (e.g., the MediaWAN protocol). The I/O board 30 shown in 
FIGURE 4 18 constructed for use with a bus network communication protocol at a 
125k baud rate, with the bus network 10 formed of fiber optic cables. 

The I/O board 58 shown in FIGURE 3 is constructed for use with a point-to- 

30 point conuminication protocol, with the transmission medium formed of the RS232 
cable 54. The I/O board 58 contains the same basic components as the I/O board 30, 
except as follows. The I/O board 58 has a single plug 82, to \^ch the RS232 
cable 54 is conxtected. Because there is only a single plug 82, the I/O tH>ard58 
indudes only one driver 84 (a RS232 driver), which is connected to the pkig. As with 

35 respect to the I/O board 30, the I/O board 58 includes a shift register 81 and an 
ASIC 83, and is connected to the pre ^ssor board 32 by a ribbon cable 87. The I/O 
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level. Such persons will also readily know how to interconnect the various 
components at the circuit level. Accordingly, to avoid unduly complicating the 
present disclosure, these details are omitted. 

Siidgs 

5 The drcuitry of the bridges 26 ilhistrated in block diagraim form in FIGURE 2 

includes many of the same components as the processor board 32 and the I/O 
cards 30, 58. The bridge processor board 44 includes a processor chip 100, e.g., one 
of the HCll family of Motorola processors. The bridge processor board 44 also 
includes a timing clock 102, a RAM 104, and a EEPROM 106. The I/O board 42 is 

10 sinular in structure to the I/O board 30, and the I/O board 40 is amiiar in structure to 
the I/O board 58. Each of the I/O boards 40, 42 include appropriate plugs for 
connecting to the type of external cable to which they are intended to be connected. 
The I/O board 42 includes fiber optic cable plugs for connecting to the bus 
network 10, and the I/O board 40 has an RS232 plug for connecting to the RS232 

15 cable 38. The I/O board 40 includes a RS232 driver 108, and the I/O board 42 
includes two fiber drivers 110 and 112. The processor chip 100 includes a UART 
port that is used to send and receive serial data from the I/O board 42. The bridge 
processor board 44 also includes an extCTnal UART (not shown) for sencfing and 
receiving serial data from the I/O board 40. 

20 The I/O boards 40, 42 also include electronic identifiers (not shown) to 

identify the transmission medium and communication protocol iwth which the I/O 
boards 40, 42 are intended to be used. At start-up initialization of the bridge 26, the 
bridge processbr board 44 determines the type of I/O boards present and selects the 
^propriate program code, as described with respect to the processor board 30. To 

25 make the bridge 26 compatible with a different transmisaon medium and/or 
communication protocol, the I/O board 40, 42 could be replaced with appropriate I/O 
boards. As is the case with respect to the processor board 32 and I/O board 30 
shown in HCjURE 4, the drcuh-level in^lonentation of the bridge can be carried out 
in various ways, as will be readily i^redated by those skilled in the pertinent art. 

30 Program Code Paradigm 

FIGURES illustrates the orgaiuzation of the program code within one 
preferred embodimient of the processor board 32 shown m FIGURE 4. The program 
code is organized into imits (referred to herein as SoftSlots) in the ROM in the 
processor 90 and in the EEPROM 92. The SoftSlots 120, 122 are based in part upon 

35 the object-oriented programming paradigm in that each SoftSlot 120, 122 b a class 
defining variables and methods (ut., fimctions). Instances, i.e., objects, of each 
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The PACKET SoftSlot 130 provides variables and methods that define 
packets, which are the unit of information communicated between devices in the 
Medialink and MediaWAN communication protocols. The PACKET SoftSlot is a 
diild of the EVENT SoftSlot, so that packets are evaits that control the execution of 

5 themselves. The PACKET SoftSlot 130 points to the UART SoftSlot 132, which 
defines variables and methods for controlling the UART within the processor 90. The 
UART SoftSlot is a child of the 10 Port SoftSlot. 

The UART SoftSlot 132 points to the MEDIALINK SoftSlot 134, which in 
turn points to the MEDIAWAN SoftSlot 136. The MEDIALINK SoftSlot provides 

10 variables and methods that define the MediaLink bus networic communication 
protocol, and the MEDIAWAN SoftSlot provides variables and methods that define 
the MediaWAN point-to-point communication protocol, supporting a 125k baud rate, 
a 9600 baud rate and other baud rates. The MEDIALINK and MEDIAWAN 
SoftSlots 134, 136 are each a child of the 10 Port SoftSlot. 

15 The MEDIAWAN SoftSlot 136 points to the Virtual Device Management 

(VDM) SoftSlot 138, which is a child of the TAPCORE SoftSlot. The VDM 
SoftSlot 138 provides variables and methods that identify the type of device, e.g., an 
amplifier, that the processor board 32 is housed in, and the VDM SoftSlot 138 
provides methods that allow the device to identify itself when queried by other 

20 devices. The VDM SoftSlot 138 also provides methods that allow the processor 90 
to write to the RAM 94 and program the EEPROM 92 on the processor board 32. 

The VDM SoftSlot 138 points to the NULL APP SoftSlot 140, which is the 
last SoftSlot within the processor 90. The NULL APP SoftSlot 140 is a child of the 
TAPCORE SoftSlot and provides variables and methods that define a generic device. 

25 The fimctionality and identity of the device in which the processor board 32 is housed 
is defined by the NULL APP SoftSlot, unless there is one or more APPLICATION 
SoftSlots 122 within the EEPROM 92. The NULL APP SoftSlot reads the identifier 
on the I/O board 30, and based thereon selects either the bus networic protocol 
defined by the. KdtEDIALINK SoftSlot 134 or the point-to-point communication 

30 protocol provided by the MEDIAWAN SoftSlot 136, as described below. 

The NULL A^ SoftSlot 140 points to the first APPLICATION SoftSlot 142 
in the EEPROM 92, if there is one. More particulariy, the NULL APP SoftSlot 140 
points to a memory location in the EEPROM 92 that points (i.t., contains the memory 
address location) of the first APPLICATION SoftSlot 142; the bytes at this memory 

35 location are ttfored to herem as link bytes. Ifthere are no APPLICATION SoftSlots 
or any other SoftSlots in the EEPROM 92, the link bytes contain zeros. In this case. 
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rate, depending on that specified by the identifier 80 on the I/O board 58. After 
locating the appropriate SoftSlot, program code contained within the SoftSlot is 
activated, as indicated at the block 160. 

Any remaining initialization steps 162 specified by subsequent SoftSlots in the 
5 linked-Ust are then performed. After the start-up initialization is completed, the 
device runs according to the activated program code contained within the SoftSlots. 

While the preferred embodiment of the invention has been illustrated and 
described, it wiU be appreciated that various changes can be made therein without 
departing from the spirit and scope of the invention. For example, while the 
10 processor board 32 described above only contained SoftSlots for two communication 
protocols, additional communication protocols can be readUy supported by including 
additional SoftSlots in the processor board 32, in the ROM in the processor 90. in the 
EEPROM 92, or in some other memory device. The electronic identifier on an I/O 
board would identify which of the communication protocols is to be used. 
15 Furthermore, while only the fiber optic I/O board 30 was described for use with the 
bus network 10, various other I/O boards could be used if a transmission medium 
otiier than fiber optics is used for the bus network 10. In this case, if the processor 
board 32 must interact differently witii different types of I/O boards for different 
transmission media, tiie SoftSlots would contain appropriate program code for each 
20 of tiie I/O board types for the various bus network transmission media. For example, 
if an I/O board constructed for a bus network formed of coaxial cables is used, U\e 
processor board 32 may require a different type of initialization. The electi-onic 
identifier on tiie VO board would identify tiie type of transmission medium, and tiie 
processor board 32 would select tiie appropriate SoftSlot program code for tiie 
25 transmission medium type. Furtiiermore, configuration in addition to that previously 
described could be performed based upon tiie identification provided by tiie electi-onic 
identifier 76. For example, it is possible tiiat a particular I/O board is to be used witii 
various electronic identifier settings. In tiiis case, tiie I/O board would configure itself 
based upon tiie electronic identifier setting. Hence, witiiin tiie scope of tiie appended 
claims, it is to be understood tiiat tiie invention can be practiced otiierwise tiian as 
specifically described herdn. 
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executing said one of said first and second units of 
program code so that said device communicates with said one or more other devices 
according to said first communication protocol. 

2. The apparatus of Claim 1, herein said processor requires no program 
code from said I/O board. 

3. The apparatus of Claim 1, wherein: 

said identification provided by said electronic identifier on said I/O 
board also identifies a baud rate at which said I/O board is intended to be used; 

said processor analyzes said identification to determine said baud rate; 

and 

said processor executes said one of said first and second units of 
program code so that said device communicates with said one or more other devices 
according to said first communication protocol at said baud rate. 

4. The apparatus of Claim 1, wherein said second connector is detachably 
connected to said first connector so that said I/O board can be disconnected from said 
processor board and a sfecond I/O board constructed to be used with a second 
communication protocol can be coupled to said processor board, said second I/O 
board including a second electronic identifier providing a second identification of said 
second commimication protocol. 

5. The q)paratus of Claim 4, wherdn said particular type of transmission 
medium to which said plug of said I/O board is connectable comprises a fiber optic 
cable, and wherdn said second I/O board is formed to be used with a second type of 
transmission medium comprising a RS232 cable. 

6. The apparatus of Claim 1, wherein said electronic identifier comprises 
a dip switch. 

7. The apparatus of Claim 1, herein said first communication protocol is 
a bus network communication protocol and said second communication protocol is a 
point-to-point communication protocol 

8. A method of automatically configuring an electronic device for 
comnnmicating with one or more other electronic devices via various communication 
protocols, said electronic device detachably connected to an I/O board constructed to 
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12. The method of Claim 8, \rfierein said first communication protocol is a 
bus network communication protocol and said second communication protocol is a 
point-to-point communication protocol. 

13. A processor board that automatically configures itself for allowing an 
electronic device to conmmnicate with one or more other electronic devices via 
various communication protocols, said processor board comprising: 

(a) a connector detachably connectable to an I/O board to couple 
said I/O board to said processor board, said I/O board being constructed to be 
connected to a particular type of transmission medium for use with a first 
communication protocol, said VO board including an electronic identifier providing an 
identification of said first commimication protocol; 

(b) memory storing first and second units of program code, one of 
which is used to communicate according to said first communication protocol and the 
other of which is used to communicate according to a second communication 
protocol; and 

(c) a processor coupled to said memory and said connector, said 

processor for: 

(i) reading said electronic identifier on said I/O board to 

determine said identification; 

^ti) axudyzing said identification to determine which of said 
first and second communication protocols is to be followed; 

(iii) selecting one of said first and seconds units of program 
code to conununicate according to said first communication protocol; and 

(iv) executing said one of said first and second units of 
program code so that said electronic device communicates with said one or more 
other devices according to said first communication protocol 

14. The processor board of Oaim 13, wherrin said processor requires no 
, program code fi'om said I/O board. 

15. The processor board of Claim 13, wherein: 

said identification provided by said electronic identifio* on said I/O 
board also identifies a baud rate at v^ch said I/O board is intended to be used; 

said processor analyzes said identification to determine said baud rate; 

and 
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